Support update expressions in single request update #6471
+1,390
−79
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Motivation and Context
This enhancement addresses the need for more flexible and powerful update operations in the DynamoDB Enhanced Client. Previously, users could only update items using POJO attributes or extension-generated expressions, but had no way to provide explicit UpdateExpressions directly in their requests. This limitation prevented users from:
This feature implements support for explicit UpdateExpressions in
UpdateItemEnhancedRequest
andTransactUpdateItemEnhancedRequest
, giving users access to all DynamoDB update features without breaking existing code.Modifications
Core Changes
Enhanced Request Models
updateExpression()
method toUpdateItemEnhancedRequest
andTransactUpdateItemEnhancedRequest
Expression Resolution System
UpdateExpressionResolver
class to merge expressions from three sources with priority-based conflict resolution:Conflict Prevention
Integration Points
UpdateItemOperation.generateUpdateExpressionIfExist()
to use the new resolverUpdateExpressionConverter
with attribute name extraction capabilitiesUpdateExpressionTest
Testing
Test Coverage
Basic Functionality Tests
Conflict Resolution Tests
Integration Tests
Edge Cases
Test Results
Test Coverage Checklist
Types of changes
Checklist
mvn install
succeedsscripts/new-change
script and following the instructions. Commit the new file created by the script in.changes/next-release
with your changes.License